import { createApp } from 'vue'
import App from '@/App.vue'
// svg插件需要配置代码
import 'virtual:svg-icons-register'
// 引入模版的全局样式
import '@/styles/index.scss'
// 引入pinia仓库
import pinia from '@/store'
// 引入路由
import router from '@/router'
// 引入element-plus插件
import ElementPlus from 'element-plus'
// 引入pinia数据持久化
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
// 导入iconfont图标
import * as ElementPlusIconsVue from '@element-plus/icons-vue'

// 配置element-plus插件的国际化
// @ts-expect-error element-plus的国际化配置未定义ts文件，因此忽略检测
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'

// 获取应用实例对象
const app = createApp(App)

// 安装element-plus插件
app.use(ElementPlus, {
  locale: zhCn, // element-plus的国际化配置
})

// 注册pinia仓库
app.use(pinia)

//pinia数据持久化
pinia.use(piniaPluginPersistedstate)

// 注册模版路由
app.use(router)

// 将icon图标注册为全局组件
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}

// 将应用挂载到挂载点上
app.mount('#app')
